@ner
2年前 提问
1个回答

sql删除表

安全侠
2年前

MySQL中删除数据表有三种方式:

  • drop table:drop 是直接删除表信息,速度最快,但是无法找回数据

    例如删除 user 表:drop table user;

    希望删除表结构时,用 drop

  • delete from:delete 是删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行

    例如删除user表的所有数据:delete from user;

    删除user表的指定记录:delete from user where user_id = 1;

    希望保留表结构,但要删除部分记录时, 用 delete

  • truncate (table):truncate 是删除表数据,不删除表的结构,速度排第二,但不能与where一起使用

    例如删除 user 表:truncate table user;

    希望保留表结构,但要删除所有记录时, 用 truncate

truncate和不带where子句的delete,drop都会删除表内的数据;truncate和delete 只删除数据不删除表结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束,触发器,索引等;drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚。